package pers.sloera.leetcode.editor.cn;//给你一个整数数组 nums ，除某个元素仅出现 一次 外，其余每个元素都恰出现 三次 。请你找出并返回那个只出现了一次的元素。
//
// 
//
// 示例 1： 
//
// 
//输入：nums = [2,2,3,2]
//输出：3
// 
//
// 示例 2： 
//
// 
//输入：nums = [0,1,0,1,0,1,100]
//输出：100
// 
//
// 
//
// 提示： 
//
// 
// 1 <= nums.length <= 3 * 10⁴ 
// -2³¹ <= nums[i] <= 2³¹ - 1 
// nums 中，除某个元素仅出现 一次 外，其余每个元素都恰出现 三次 
// 
//
// 
//
// 进阶：你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗？ 
//
// 
//
// 注意：本题与主站 137 题相同：https://leetcode-cn.com/problems/single-number-ii/ 
// Related Topics 位运算 数组 👍 56 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
// class Solution {
class SolutionII004 {
    //   public static void main(String[] args) {
    //     final SolutionII004 solutionII004 = new SolutionII004();
    //     System.out.println(solutionII004.singleNumber(new int[]{0,1,0,1,0,1,100}));
    //   }
    public int singleNumber(int[] nums) {
        int result = 0;
        for (int i = 0; i < 32; i++) {
            int temp = 0;
            for (int num : nums) {
                temp += (num >> i) & 1;
            }
            // 当前位为0
            if (temp % 3 == 0) {
            } else {
                // 当前位为1
                result |= 1 << i;
            }
        }
        return result;
    }
}
//leetcode submit region end(Prohibit modification and deletion)
